Look for zstd before Clang
authorPino Toscano <pino@debian.org>
Mon, 21 Apr 2025 08:01:50 +0000 (10:01 +0200)
committerPino Toscano <pino@debian.org>
Mon, 21 Apr 2025 08:01:50 +0000 (10:01 +0200)
commit8d5e8898619cc87acda3069f0e044db9f5096e0b
tree24991b53109bfc3f1fb2c644e6c4ef88fea042ab
parente5519d2e9f9cd1e3a3dda788c7835883439a91d8
Look for zstd before Clang

Last-Update: 2024-07-17
Forwarded: not-needed

The story is more or less the following:
- LLVM ships its own Findzstd cmake find module from 16; this module defines
  2 targets: zstd::libzstd_shared and zstd::libzstd_static
- libzstd ships a cmake config module that defines 3 targets:
  zstd::libzstd_shared, zstd::libzstd_static, and zstd::libzstd
- the libzstd config module assumes that if one target is defined, all of them
  are, as if the config module itself was already run (i.e. multiple
  "find_package(zstd)" in a cmake project)
- in qttools, Clang is searched first, which in turns requires LLVM, and then
  libzstd

More details here: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1073480#47

As workaround, look for libzstd before Clang: this way the proper zstd cmake
targets are defined, and the Findzstd cmake find module shipped with LLVM will
use them just fine without redefining them.

This should most likely be fixed on LLVM side.

Gbp-Pq: Name cmake-find-zstd-before-clang.diff
configure.cmake
src/designer/src/lib/CMakeLists.txt